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METHOD AND SYSTEM FOR COLLABORATING AMONG INTERCONNECTED 

CLIENT TERMINALS 

Field of the Invention 

The present invention relates to a method of information processing, and in particular 
to a method for sending information on the client side to the server side. 

Background of the Invention 

The Internet comprises multiple computer networks interconnected so that any computer 
on a given network can communicate with one or plural computers on any other given network. 
A gateway computer is a computer interconnecting two networks and passing data from one 
network to another network. 

All the computers on the Intemet communicate via a specific communication protocol, 
namely the Intemet Protocol. Most applications use Transmission Control Protocol (TCP) 
along with the Intemet Protocol. Accordingly, the Intemet is also called the TCP/IP network. 
A computer connected to the Intemet is identified by a unique Intemet address. 

The Intemet performs routing of information by using the well-known packet switching 
technique. On the Intemet, data is transmitted via a packet with an address (also called an IP 
packet). General Intemet applications include those incorporating electronic mail, FTP, 
TELNET, network news, etc. The Intemet protocol and applications are well known. 

World Wide Web (namely, WWW or Web) is an information service system based on 
the Intemet. WWW uses hypertext and client/server techniques. Hypertext is a method for 
stmcturing and presenting information so that a data object in a hypertext file can have a link 
to another hypertext file or data object. For instance, while a hypertext page is displayed, a user 
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can select a word which has a link. Accordingly, the user can move to another hypertext file 
including another text or picture to explain the word (there are cases where the new file also has 
a link to another hypertext file, and fi-om then on they are linked likewise). 

Currently, many of hypertext files are composed by using hypertext markup language 
(HTML). A hypertext data object can be almost any information medium such as text, image, 
speech, image sequence or an executable computer program. Any hypertext file on the Web 
is uniquely identified by its universal resource locator (URL). 

A Web client or a client (ii^eneral, a computer which executes a program called a 
rowser) is essentially a hypertext reader which communicates with a Web server via a specific 
data transfer protocol such as the hypertext transfer protocol (HTTP). A client requests a 
hypertext file by using the appropriate UIu^ and displays the file (called a Web page) on a 
graphical user interface (GUI). A client can \lso return specific data to a server and call a 
common gateway interface (CGI) program to perform a specific task. Currently, Netscape 
Navigator (trademark of Netscape Communicmons Corporation) and Internet Explorer 
(trademark of Microsoft Corp) are known as generakbrowsers. 

WWW allows a user anywhere on the Internet t\send a hypertext file on WWW by 
using the worldwide connections of the Intemet, and allows any hypertext file to be fetched as 
conveniently as using a local hard disk. Thus, a user is given a strong tool for acquiring 
information, and the Intemet becomes a hypermedia global database, namely an information 
superhighway. 

The Intemet and WWW have been dramatically expanding in recent years. Companies 
also expect a great opportunity in the use of the Intemet and WWW as a new-generation 
worldwide communication basis for advancing into a huge consumer market. 



In such Intemet technologies, there exists a technology which uses a whiteboard to refer 
to common information with two terminals connected with a network 
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(http://www.vocaltec.com/iphone4/ip4.htm, etc.). However, such a technology merely sends 
information, to be mutually referred to, to the other party connected by using the HTTP 
protocol, and does not allow access to that information again after a session has ended. 

Moreover, even during a session, the information cannot be accessed by a third party. 
5 In addition, since data commonly referred to is displayed on the Web browser, the number of 

windows displayed on a desktop can be reduced. Also, in one aspect of the present invention, 
each user has a unique name to be stored on a server, and thus a file created by a specific user 
can be specified and referred to. 

Q In conjunction with the problems to be solved by the present invention, Japanese 

'£iO Unexamined Patent Publication No. Hei 10-247176 activates an applicafion on a Web server 

ill fi*om a client terminal side to have a running state of the application displayed on the Web 

^ browser screen of the client terminal. To utilize this technology, however, it is necessary to 

y register an application to run on the server in advance. Also, since an application is run in 

^ compliance with a request fi*om the client terminal, the server's burden increases. Moreover, 

ul 5 since an application is run in response to a request fi-om the client terminal and the result, etc. 

are sent to the client terminal, there are drawbacks, namely, conraiunication time becomes 

flj; longer and the load to the system increases. 

On the other hand, as in Japanese Unexamined Patent Publication No. Hei 1 0- 1 2446 1 , 
a collaboration technology is proposed, which allows plural users to simultaneously perform 

20 collaborative work on an HTML page (access, loading or change). Fig. 1 1 is a diagram 

showing an example of applying this collaborative work on an HTML page to an Internet 
banking system. This technology allows an event, etc. occurred on a URL or a Web browser 
specified by one user to be sent to another user's terminal so that reference to a common page, 
etc. can be made. If this technology is used, a bank agent can refer to the same page as a 

2 5 customer and simultaneously have communication such as mutually confirming its contents by 

telephone 1365A and 1365B. 
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In communicating with another operator in a remote place by using such a collaboration 
technology, there was a request asking that a state of an application other than a Web browser 
is immediately shown to the other operator. 

SUMMARY OF THE INVENTION 

One object of the present invention is to display information existing on a client terminal 
onto a display screen of another client terminal by performing a simple operation. 

Another object is to display information existing on a client terminal onto a display 
screen of another client terminal while minimizing the number of applications operating on a 
desktop. 

A further object is to display an operating state of an application not directly related to 
communication onto a display screen of another client terminal connected with a network. 

A still further object is to provide a computer system which does not depend on a 
platform of the operated information terminal. 

In one aspect of the present invention, if an image displayed on a display screen of 
another client terminal is specified, the image is compressed to predetermined formed image 
data and also given a unique name in the system. This file is automatically sent to a Web 
server. A Web browser operating on a client terminal is automatically switched to display 
the file. 

In another aspect of the present invention, a method of communicating on a 
communication system having a client terminal connecting a server through a network and 
collaborating with other client terminals connected to the network is provided, the method 
comprising the steps of: (a) generating an image file in response to specifying an image area 
by an operator of the client terminal; (b) acquiring an image file name fi-om the server; (c) 
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converting the image file to generate a predetermined formed compressed image data which 
has a file name relating to the image file name; (d) sending the predetermined formed 
compressed image data to the server; (e) displaying the predetermined formed compressed 
image data of the server on a Web browser on the client terminal; and (f) posting the file 
name of the predetermined formed compressed image data to the client terminals 
collaborating with the client terminal. 

As used herein, "an image area" is a concept including not only "a square range 
specified by an operator" explained in the preferred embodiments of the present invention 
but also "a range currently displayed by a specific application window," etc. Moreover, 
while "an image file name" is a concept corresponding to "an original name" explained in 
the preferred embodiments of the present invention, it can suitably be a name capable of 
identifying an operator and is a concept including a user ID, an IP address, etc. 

In a further aspect of the present invention, a method of communicating on a 
communication system having a client terminal connecting a server through a network is 
provided, the method comprising the steps of: (a) generating an image file in response to 
specifying image data by an operator of the client terminal; (b) determining a unique image 
file name on the server; (c) converting the image file to generate a predetermined formed 
compressed image data which has a file name relating to the unique image file name; (d) 
sending the predetermined formed compressed image data to the server; and (e) displaying 
the predetermined formed compressed image data of the server on a Web browser on the 
client terminal. 

In a still further aspect of the present invention, a method of conmiunicating on a 
communication system having a client terminal connecting a server through a network is 
provided, the method comprising the steps of: (a) generating an image file in response to 
specifying image data by an operator of the client terminal; (b) converting the image file to 
generate a predetermined formed compressed image data; (c) sending the predetermined 
formed compressed image data to the server; (d) determining a unique image file name on 
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the server and posting it to the chent terminal; and (e) displaying the predetermined formed 
compressed image data of the server on a Web browser on the client terminal. 

In a still further aspect of the present invention, a method of communicating on a 
communication system having a client terminal connecting with a network and a server 
connecting with the network and storing a file created by an operator of the client terminal 
which has a name capable of determining that it was created by the operator is provided, the 
method comprising the steps of: (a) receiving a message sent fi"om the client terminal 
including information capable of identifying the operator; (b) acquiring the information 
capable of identifying the operator included in the message; (c) acquiring the file name of 
the file created by the operator based on the information capable of identifying the operator; 
(d) generating a file list file by inserting the file name into a skeleton file; and (e) posting the 
file name of the file list file to the client terminal. 

In the claims of the specification of the present invention, while "information 
capable of identifying an operator" is a concept corresponding to "an original name" 
explained in the preferred embodiments of the present invention, it can suitably be a name 
capable of identifying an operator and is a concept including a user ID, an IP address, etc. 

In a still further aspect of the present invention, a client terminal connecting a server 
through a network and collaborating with other client terminals connected to the network is 
provided, the client terminal comprising: (a) a screen range selector for specifying a screen 
range in response to operation for specifying screen range by an operator; (b) an image file 
generator for acquiring an image according to the screen range and generating an image file; 
(c) a file name acquisition division for acquiring an original name from the server; (d) an 
image file converter for converting the image file to generate a predetermined formed 
compressed image data; (e) a file transmitter for sending to the server the predetermined 
formed compressed image data which has a file name relating to the original name; and (f) a 
display division for displaying the predetermined formed compressed image data of the 
server on a Web browser on the client terminal. 
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In a still further aspect of the present invention, a server connecting a client terminal 
through a network and storing a file created by an operator of the client terminal which has a 
file name capable of determining that it was created by the operator is provided, the server 
comprising: (a) a message analysis division for receiving a message sent fi-om the client 
terminal including information capable of identifying the operator and acquiring the 
information; and (b) a file list generator for acquiring the file name of the file created by the 
operator based on the information, generating a file list file by inserting the file name into a 
skeleton file; and posting the file name of the file list file to the client terminal. 

In a still further aspect of the present invention, a communication system having a 
first and a second client terminals connecting with a network and a server connecting the 
first and a second client terminals through the network is provided, the communication 
system comprising: the first client terminal comprising: (al) an image file generator for, in 
response to operation for specifying a screen range by an operator, generating an image file 
according to the operation; (a2) a file name acquisition division for acquiring an original 
name from the server; (a3) an image file converter for converting the image file to generate a 
predetermined formed compressed image data; (a4) a file transmitter for sending to the 
server the predetermined formed compressed image data which has a file name relating to 
the original name; and (a5) a display division for displaying the predetermined formed 
compressed image data of the server on a Web browser on the first client terminal and 
posting the name of the predetermined formed compressed image data to the second client 
terminal, and (b) a server comprising a file name generator for generating an original name 
capable of uniquely identifying the first client terminal in response to a request from the first 
client terminal and posfing it to the first client terminal; and (c) the second client terminal 
for displaying the predetermined formed compressed image data of the server on a Web 
browser on the second client terminal based on the name of the predetermined formed 
compressed image data sent from the first client terminal. 

In a still further aspect of the present invention, a storage medium storing a software 
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product for connecting a server through a network and controUing conrmiunication 
performed on a communication system having a chent terminal collaborating with other 
client terminals connected to the network is provided, the software product comprising the 
program codes for: (a) directing the client terminal to generate an image file in response to 
specifying an image area by an operator of the client terminal; (b) directing the client 
terminal to acquire an image file name fi-om the server; (c) directing the client terminal to 
convert the image file and generate a predetermined formed compressed image data which 
has a file name relating to the image file name acquired from the server; (d) directing the 
client terminal to send the predetermined formed compressed image data to the server; (e) 
directing the client terminal to display the predetermined formed compressed image data of 
the server on a Web browser on the client terminal; and (f) directing the client terminal to 
post the file name of the predetermined formed compressed image data to the client 
terminals collaborating with the client terminal. 

/ In a still further aspectS^f the present invention, a storage medium storing a software 
product for controlling communWtion performed on a communication system having a 
client terminal connecting a server Wough a network is provided, the software product 
comprising the program codes for: (amirecting the client terminal to generate an image file 
in response to specifying image data by an operator of the client terminal; (b) directing the 
client terminal to determine a unique imagesfile name on the server; (c) directing the client 
terminal to convert the image file and generatka predetermined formed compressed image 
data which has a file name relating to the image^le name acquired from the server; (d) 
directing the client terminal to send the predetermiked formed compressed image data to the 
server; @and (e) directing the client terminal to dispmy the predetermined formed 
compressed image data of the server on a Web browsenon the client terminal 

In a still further aspect of the present invention, a storage medium storing a software 
product for controlling communication performed on a communication system having a 
client terminal connecting a server through a network is provided, the software product 
comprising the program codes for: (a) directing the client terminal to generate an image file 
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in response to specifying image data by an operator of the client terminal; (b) directing the 
client terminal to convert the image file and generate a predetermined formed compressed 
image data; (c) directing the client terminal to send the predetermined formed compressed 
image data to the server; (d) directing the client terminal to determine a unique image file 
name on the server and post it to the client terminal; and (e) directing the client terminal to 
display the predetermined formed compressed image data of the server on a Web browser on 
the client terminal. 

In a still further aspect of the present invention, a storage medium storing a software 
product for controlling communication performed on a conamunication system having a 
client terminal connecting with a network and a server connecting with the network and 
storing a file created by an operator of the client terminal which has a file name capable of 
determining that it was created by the operator is provided, the software product comprising 
the program codes for: (a) directing the server to receive a message sent from the client 
terminal including information capable of identifying the operator; (b) directing the server to 
acquire the information capable of identifying the operator included in the message; (c) 
directing the server to acquire the file name of the file created by the operator based on the 
information capable of identifying the operator; (d) directing the server to generate a file list 
file by inserting the file name into a skeleton file; and (e) directing the server to post the file 
name of the file list file to the client terminal. 

Brief Description of the Drawings 

For a more complete understanding of the present invention and for further advantages 
thereof, reference is now made to the following Detailed Description taken in conjunction 
with the accompanying drawings, in which: 

Fig. 1 is a conceptual diagram of an information processing system in a preferred 
embodiment of the present invention; 
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Fig. 2 is a block diagram showing an embodiment of hardware configuration of a 
cUent terminal or a server in the present invention; 

Fig. 3 is a block diagram of processing elements on a client terminal side in a 
preferred embodiment of the present invention; 

Fig. 4 is a block diagram of processing elements on a server side in a preferred 
embodiment of the present invention; 

Fig. 5 is a flowchart explaining a procedure on a client terminal side in a preferred 
embodiment of the present invention; 

Fig. 6 is a flowchart explaining a procedure on a client terminal side in a preferred 
embodiment of the present invention; 

Fig. 7 is a flowchart explaining a procedure on a Web server side in a preferred 
embodiment of the present invention; 

Fig. 8 is a diagram showing a display screen of a client terminal in a preferred 
embodiment of the present invention; 

Fig. 9 is a diagram showing a display screen of a client terminal in a preferred 
embodiment of the present invention; 

Fig. 10 is a diagram showing a display screen of a client terminal in a preferred 
embodiment of the present invention; and 

Fig. 1 1 is a flowchart for explaining a conventional collaboration technology. 
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Detailed Description of the Invention 



A. Overview 

**YV>r7 ^^8' ^ ^ conceptual diagram of a data processing system in a preferred 

^ / embodiment of the present invention. On information terminals 1 10 and 120 on the client 
5 side, Web browsers such as Netscape Navigator (a trademark of Netscape Conmiunications 

Corporation) and Intemet Explorer (aVrademark of Microsoft Corp.), etc. are installed. The 
operator of client terminal 1 1 0 selects an image and a file displayed on a desktop after 
moving processing elements of the present invention, and then the data processing system of 
J the present invention determines a uniqueVmage file name in the system and generates 

1 0 predetermined formed compressed image data. 

' The compressed image data is sent to Web server 140, and then the Web browser's 

% location is changed to a URL including this file and displayed. In one aspect of the present 

invention, this URL is also posted to another collaborating client terminal 120 so that the 
file sent to Web server 140 can be displayed. If accessed by specifying the URL, this file 
1 5 can also be referred to firom client terminal 121 which is not collaborating. 

B. Hardware Configuration 



Fig. 2 is an overview showing an embodiment of hardware configuration of client 
terminals 110, 120 and Web server 140 used in the present invention. Client terminals 1 10, 
120 and Web server 140 comprise central processing unit (CPU) 1 and memory 4. CPU 1 
20 and memory 4 are connected via bus 2 with hard disk device 1 3 as auxiliary storage. 

Floppy-disk drive 20 (or drives for storage media such as CD-ROM drive 26, magneto- 
optical drive(MO) 28, or CD-ROM drive 29) is connected with bus 2 via floppy-disk 
controller 19 (or IDE controller 25, SCSI controller 27, etc.). 



A floppy disk (or a storage medium such as an MO or a CD-ROM) is inserted into 
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floppy-disk drive 20(or appropriate drives 26, 28, or 29). Code of a computer program for 
giving instructions to a CPU in synergy with an operating system to implement the present 
invention can be recorded on storage media for execution by being loaded to memory 4. 
This code can also be compressed or divided so as to be recorded on two or more media. 

OJiTy^ Client terminals 1 10, 120 and v^b server 140 can also have user interface hardware 
y including pointing device 7(a mouse, a jos/stick etc.) or keyboard 6 and display 12. A touch 
panel can also be a means for entry. It is ar$o possible to connect with a printer via parallel 
port 16 or a modem via serial port 15. This information terminal support server 100 can be 
connected with a network via serial port 15 and\ modem or communication adapter 18 
(Ethernet or Token-ring card) etc. so as to communicate with other computers and so on. 

Speaker 23 receives a speech signal which is D/A (digital/analog) converted by 
audio controller 21 via amplifier 22 and provides output as speech. In addition, audio 
controller 21 makes it possible to convert speech information received from microphone 24 
and capture into the system speech information outside the system. 

Thus, it may be easily understood that client terminals 110, 120 and Web server 140 
in the present invention are implemented by information terminals with a conraiunication 
facility including an ordinary personal computer (PC) or a workstation, a notebook PC, a 
palmtop PC, a network computer, etc. or a combination of these. However, these 
components are taken as examples, and it does not follow that all of them are required 
components of the present invention. 

In particular, since the hardware configuration explained here also includes the items 
not required for control on a client terminal such as specifying a screen area or a file and 
sending it to a server, a client terminal can do without audio controller 21, amplifier 22, 
speaker 23 and microphone 24 required for speech processing, and keyboard 6, mouse 7, 
keyboard/mouse controller 5, various record medium processors 19, 25, 27, etc. allowing 
direct entry from an operator. 
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Also, a server can do without audio controller 21, amplifier 22, speaker 23 and 
microphone 24 required for speech processing, keyboard 6, mouse 7, keyboard/mouse 
controller 5 allowing direct entry from an operator, and CRT 12, display 1 1, VRAM 9, VGA 
8, various record medium processors 19, 25, 27, etc. for presenting visual data to a user. As 
for the components of client terminals 110, 120 and Web server 140, various changes can be 
easily assumed by this trader including combination of plural machines for allotting and 
implementing functions among them, and such changes are the concepts incorporated in the 
philosophy of the present invention. 

An operating system for client terminals 1 10, 120 and Web server 140 can be 
implemented by those supporting a GUI multi window environment as a standard such as 
Windows NT (a trademark of Microsoft Corp.), Windows 9x (a trademark of Microsoft 
Corp.), Windows 3.x (a trademark of Microsoft Corp.), OS/2 (a trademark of IBM Corp.), 
MacOS (a trademark of Apple Corp.) and X- WINDOW system (a trademark of MIT) on 
AIX (a trademark of IBM Corp.), those of character-based environments such as PC-DOS (a 
trademark of IBM Corp.) and MS-DOS (a trademark of Microsoft Corp.), real time 
operating systems such as OS/Open (a trademark of IBM Corp.) and Vx Works (a trademark 
of Wind River Systems, Inc.), and operating systems incorporated in a network computer 
such as JavaOS, and thus it is not limited to a specific operating system environment. 

C. System Configuration 

Fig. 3 is a functional block diagram showing a system configuration of client 
terminals 1 10 and 120 in a preferred embodiment of the present invention. A client terminal 
has Web browser 21 1, control division 212, screen range selector 213, image file generator 
214, image file converter 215, file name specification/transmitter 216, display division 217, 
Web browser display window 218, existing image file selector 219, existing file selector 
220, erasure request division 221, file list acquisition division 222, file name acquisition 
division 223 and setting division 224. 
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Web browser 211 sends a request to Web server 140 and also receives a response 
sent from Web server 140 to display on a display screen. Control division 212 provides an 
input area for an operator to select a function of the present invention and also performs 
flow management when each of the processing components implement the procedure of the 
present invention. 

Screen range selector 2 1 3 identifies a screen area specified by an operator via input 
division 210. It also passes to display division 217 coordinate data, etc. to visually display 
an identified screen area. Image file generator 214 generates an image file by acquiring 
image data of the screen area specified by screen range selector 213. 

Image file converter 215 converts an image file generated by image file generator 
214 into a file format specified by an operator via input division 210. File name 
specification/transmitter 216 posts a file name acquired by file name acquisition division 
223 to other collaborating client terminals and display division 217. 

Display division 217 controls Web browser display window 218 to browse the file 
name posted by file name specification/transmitter 216. Web browser display window 218 
acquires specified URL data and displays it on the display screen. 

Existing image file selector 219 performs control for having an operator select an 
image file existing on client terminal 110. Existing file selector 220 performs control for 
having an operator select a file in a format other than an image file existing on client 
terminal 1 1 0. 

Erasure request division 221 performs control for erasing a file from Web server 140 
specified by an operator via input division 210. File list acquisition division 222 performs 
control for acquiring a file list existing on Web server 140. 

File name acquisition division 223 requests Web server 140 to give a unique name in 
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the system and acquires a file name sent from Web server 140. In a preferred embodiment 
of the present invention, file name acquisition division 223 is activated when an operation of 
file selection such as screen range selection, image file selection or any other file selection is 
first performed after control division 212 is activated, and it requests Web server 140 to 
generate a file name. Moreover, it passes the file name acquired fi'om Web server 140 to 
control division 212. Setting division 224 performs initialization, etc. when this client 
terminal 110 is activated. 

Fig. 4 is a functional block diagram showing a system configuration of Web server 
140 in a preferred embodiment of the present invention. Web server 140 has message 
analysis division 264, file name generator 260, file erasure division 261, file list generator 
262 and setting division 263. 

File name generator 260 generates a unique name in the system in response to a file 
name generation request sent fi'om file name acquisition division 223 of client terminal side 
1 10, and sends it in a format of a file name generation response to file name acquisition 
division 223. 

File erasure division 261 performs file erasure in response to a file erasure request 
sent fi*om file erasure request division 221 of client terminal side 1 10 and sends its status to 
the file erasure request division. 

File list generator 262, in response to a file list generation request sent fi"om file list 
acquisition division 222 of client terminal side 1 10, acquires a listing of files managed by a 
client that sent the request, generates a file list and sends it in a format of a file list 
generation response to file list acquisition division 222. 

Setting division 263 performs inifialization, etc. when this Web server 140 is 
activated. Message identification division 264 identifies the type of message sent fi"om the 
client side. 
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While each of the functional blocks shown in Figs. 3 and 4 were explained as above, 
these are logical functional blocks, and each of them is meant to be implemented not by one 
integrated hardware and software but by combined or common hardware and software. 
Also, it does not mean that all the functional blocks shown in these Figs, 3 and 4 are the 
components required for the present invention. 

For instance, in a form wherein, as a method, it is not that the file name acquisition 
division acquires an original name in advance and determines a file name based on this 
original name, but that a file name sent by file name specification/transmitter 216 is 
converted into a unique file name in the system on the server side and it is posted to the 
client terminal side, file name acquisition division 223 is not necessary. 

D. Operating Procedure 

The operating procedure of each processing element of client terminals 110 and 120 
in a preferred embodiment of the present invention is shown in Figs. 5 and 6. 

As shown in Fig. 5, the procedure starts with step 400. First, if the system is 
activated, processing elements of the present invention are activated and various 
initialization is performed (step 401). In response to operator input, control division 212 
(Fig. 3) is activated. 

Control division 212 in a preferred embodiment of the present invention provides a 
function for an operator to input selection of the screen image transmission process (step 
402), the existing image file transmission process (step 403), the other existing file 
transmission process (step 404), the file erasure process (step 405), the file list acquisition 
process (step 406) and the end (step 407) (Fig. 8). If the operator selects these functions, 
software related to thereto is activated. 

D-1 . Screen image transmission procedure 
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If control division 212 determines that an operator input is a screen image 
transmission process, screen range selector 213 specifies an image on a desktop by a 
"rubber-band range specification function" or a "square-fi-ame-highlighting window 
selection function", etc. (step 500, Fig. 6). 

D-l-l. Rubber-band range specification function 

In one aspect of the preferred embodiments of the present invention, control division 
212 has a rubber-band range specification function. If it is determined that an operator input 
is a screen image transmission process, and the left mouse button is pressed and the mouse 
pointer is moved, this rubber-band range specification function shows a rubber band on a 
display screen. The operator performs an operation of moving the mouse pointer to expand 
the rubber band to the range to be cut as an image and then pressing the left mouse button 
once. 

Moreover, in one aspect of the preferred embodiments of the present invention, 
width and height of an image to be cut are also displayed in response to the mouse pointer's 
movement. Furthermore, while in a preferred embodiment of the present invention, the 
range to be cut is specified by pressing the left mouse button and moving the mouse pointer 
and then pressing the left mouse button once more, the range can also be specified by an 
operation such as a drag and release. 

To be specific, screen range selector 213 temporarily stores the mouse pointer's 
coordinate value first in response to a click of the left mouse button, and then acquires the 
mouse pointer's coordinate value to where it is moved in response to detection of the mouse 
pointer's movement. Based on such information, it generates information to display a square 
frame which is sent to display division 217. Thus, a square frame which expands and 
reduces in response to the mouse pointer's movement is displayed on the display screen. 

If a range to be cut is decided by this operation, in a preferred embodiment of the 
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present invention, screen range selector 213 further highlights the square selected by the 
rubber band (changes a display attribute of the square frame) and shows a pop-up menu to 
have the operator select " 1 : Capture", "2: Redo" or "3: Terminate". 

If the operator selects " 1 : Capture", a bit map file is generated in image file generator 
214 (step 501). To be specific, a bit map file is generated in the following procedure: 

1 . First, in the case of cutting based on range specification, a device context of a desktop 
window is acquired. 

2. A memory device context compatible with this desktop window device context is 
generated. 

3. A bit map of range-specified size (in the case of a window, window size) corresponding 
to this memory device context is generated in memory. 

4. Of the bit map of the desktop window device context, the range-specified part is copied to 
the memory device context. 

5. The bit map is converted into a device independent bit map by utilizing a clipboard. 

6. A bit map file is generated by writing in a file a Bitmap file header and the device 
independent bit map. 

The bit map file generated in the image file generator is converted into a JPEG file, a 
GIF file, etc. in image file converter 515 (step 502). Moreover, the file format to be 
converted into may be a format specified by an operator. 

In a preferred embodiment of the present invention, a file name on a Web server is a 
unique name on this system capable of proving that it was generated by a function of the 



18 



JA998217 



present invention. For instance, if a name acquired in advance by file name acquisition 
division 223 on a Web server (an original name) is X, it can be named by using a formula: 
(*'dplmg" + X + a serial number), etc. 

Moreover, in a preferred embodiment of the present invention, while an original 
name is acquired in advance fi^om Web server 140 and a file name is determined each time a 
file is sent to Web server 140 in order to reduce traffic of client terminal 1 10 and Web server 
140, it is also possible to adopt a method for converting a file name sent by file name 
specification/transmitter 216 into a unique file name in the system on the server side and 
posting it to the client terminal side. 

The converted file is sent to the Web server by file name specification/transmitter 
216. In a preferred embodiment of the present invention, this transmission is performed by 
using a method set by setting division 224 (a PUT method of HTTP or FTP, etc.) (step 504). 

Display division 217 changes a URL of Web browser display window 218 to "an 
HTML including a transmitted file" and displays an image (step 504). 

D-1-2. Square-fi-ame-highlighting window selection fiinction 

In another aspect in a preferred embodiment of the present invention, a screen area is 
specified by using the square-fi*ame-highlighting window selection fiinction. If this function 
is used, when an operator moves a mouse, a frame of a visible window under it is 
highlighted. And if the operator moves the mouse on the window to be acquired and presses 
the right mouse button, and in the case that a part of the subject window is hidden under 
another window, all of it is displayed with its frame fiirther highlighted. And just as in 
"D-1-1. Rubber-band range specification fijnction", a pop-up menu for selecting "1: 
Capture", "2: Redo" or "3: Terminate" is displayed. The operator selects it by the right 
mouse button. 
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In such an operation, in response to detection of the mouse pointer's movement, 
screen range selector 213 inquires of the window system about visible window size and 
position of an application closest to the current mouse pointer's position so as to display a 
square corresponding to the window frame. While this square corresponding to the window 
frame can be directly rendered on a desktop, it is also possible to generate a transparent 
window and render the square on it. After that, in response to detection of pressing of the 
right mouse button, it displays in front a window of an application closest to the current 
mouse pointer's position and also highlights a square corresponding to the window frame. 

If the operator selects " i : Capture", a bit map file is generated in image file generator 
214 (step 501). To be specific, it is almost the same as "D-1-1. Rubber-band range 
specification ftinction" except that, in the case of window specification, a device context of 
the subject window rather than a device context of the desktop window is acquired. 

D-1-3. Capture suspend/resume fimction for displaying another application 

In a preferred embodiment of the present invention, a capture suspend/resume 
fiinction for displaying another application is provided as an additional fiinction. As the 
mouse is captured when screen range selector 213 is activated, only the images currently 
displayed on a desktop are the subjects for acquisition. In order to acquire an application yet 
to be activated, a hidden window image and a full-screen display application image, a range 
selection process can be suspended and resumed by an operation such as Windows hot key 
(default: Capture suspend: Shift + X, Capture resume: Shift + C), etc. The hot key can be 
changed by setting division 224. 

D-1-4. Full-screen display applicafion image size restore ftinction 

In a preferred embodiment of the present invention, a full-screen display application 
image size restore function is further provided as an additional function. It is a function 
wherein, if capture is performed making the subject window a ftiU-screen window in order 
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to capture a full-screen image of an application, the subject window is automatically 
restored to its original size after the capture is performed. In a preferred embodiment of the 
present invention, it is implemented by screen range selector 213 sending a restore 
command to the window system. 

D-2. Existing image file transmission procedure 

In the existing image file transmission procedure in a preferred embodiment of the 
present invention, existing image file selector 219 displays a dialog for file selection, and 
extracts and displays files of the file extensions (BMP, GIF, JPG) existing in a specified 
directory of a client terminal (step 510). If a file is selected by an operator, the file is 
accessed and converted into a predetermined file format (step 511). In a preferred 
embodiment of the present invention, in the case of a bitmap file, image file converter 215 
converts the file into a file of GIF or JPG format. 

And just as in the procedure of "D- 1-1. Rubber-band range specification function", it 
is sent to a Web server with a unique name in the system and is displayed on a Web browser 
(steps 512 and 513). 

D-3. Other existing file transmission procedure 

The other existing file transmission function can be used to send various files on a 
Web server. In a preferred embodiment of the present invention, it is possible to control 
who can access the file then. First, it is possible to specify that only those performing Web 
browser collaboration can access it (hereafter called private) or that anyone capable of 
accessing this system can access it (hereafter called public). 

D-3-1. Private 

An operator can use existing file selector 220 to display a dialog for file selection 
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and select a file (step 520). The file is sent to a Web server by file name 
specification/transmitter 216. It is sent by a method set by setting division 224 (a PUT of 
HTTP or FTP) (step 521). 

In that case, a file name on a Web server must be a unique name on this system 
capable of proving that it was generated by this function, and also capable of determining 
that it is private. For instance, if a name acquired in advance by file name acquisition 
division 223 on a Web server is X, it can be named by using a formula: ("dpPrivate" + X + a 
serial number), etc. 

It is also possible to create and send a table file associating information such as 
original names of transmitted files with unique names given here. This is because, in the 
process of acquiring a file list mentioned later, it is not possible to distinguish contents of 
unfamiliar names allocated in the system even if they are listed. For instance, a file can be 
named by using a formula: ("dpFilelnfo" + X). In a preferred embodiment of the present 
invention, this one file exists in a session of Web browser collaboration (hereafter, fi-om a 
start to an end of PC collaboration is called a session). 

D-3-2. Public 

An operator can, as in the case of private, use existing file selector 220 to display a 
dialog for file selection and select a file. The selected file is sent to Web server 140 by file 
name specification/transmitter 216. In a preferred embodiment of the present invention, it is 
sent by a method set by setting division 224 (a PUT method of HTTP or FTP, etc.). 

A file name on a Web server must be a unique name on this system capable of 
proving that it was generated by this function, and also capable of identifying that it is 
public. For instance, if a name acquired in advance by file name acquisition division 223 on 
a Web server is X, it can be named by using a formula: ("dpPublic" + an original file name 
("." is changed to "_") + X), etc. 
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D-4. File erasure procedure 

If an operator activates file erasure request division 221, file erasure request division 
221 displays entries for entering the name X acquired in advance by file name acquisition 
division 223 and selecting an image, a file (private) or a file (public) (plural combinations 
are also possible). The information entered in these entries is sent to Web server 140 as a 
servlet (step 530). 

Web server 140 receives the servlet and activates file erasure division 261 and then 
erases an applicable file to return the result to the client server side. File erasure request 
division 22 1 displays the result by a method such as a dialog box (step 53 1). 

In addition, file erasure division 261 on Web server 140 can perform a process of 
automatically erasing a file past the time set by a timer. The time and files to be erased, etc. 
can be set in advance in setting division 263 of Web server 140. 

D-5. File list acquisition procedure 

If an operator activates file list acquisition division 222, entries are displayed for 
entering the name X acquired in advance by file name acquisition division 223 and selecting 
private or public (plural combinations are also possible). The information entered in these 
entries is sent to Web server 140 as a servlet (step 540). 

Web server 140 receives it and activates file list generator 262 and then generates an 
HTML file with a link to an applicable file to return its URL to client terminal 1 10 v^hich 
sent the request. 

File list acquisition division 222 on client terminal 1 10 posts the URL to display 
division 217. Display division 217 acquires it and directs Web browser display window 218 
to display this URL. 
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D-6. Termination 

In a preferred embodiment of the present invention, if termination is selected by an 
operator and in the case that a file was transmitted in this session, the "erasure of subject 
files on Web server" fiinction is automatically performed. It is also possible to set a 
parameter, etc. in setting division 224 whether to perform it or not. 

E. Operating Procedure of Web Server 

The operating procedure of each processing element of Web server 140 in a 
preferred embodiment of the present invention is shown in Fig. 7. Web server 140 starts the 
procedure of the present invention in response to receiving a message fi-om client side 
terminal 1 10 (or 120) (step 600). When Web server 140 receives a message fi:om a client 
terminal 1 10, message analysis division 264 analyzes if the message is a file name 
generation request (step 601), a file erasure request (step 610) or a file list generation request 
(step 620). Message analysis division 264 in a preferred embodiment of the present 
invention also checks whether a user who sent a message is authorized to perform a process 
according to the request. 

If an analyzed request is a file name generation request, a file name generation 
process is performed (step 602). In a preferred embodiment of the present invention, a file 
name meeting the following conditions is generated: 1 . A unique name in the system; 2. A 
neighboring user cannot imagine it; and 3. A stranger cannot easily imagine it. 

For instance, a file name meeting the above conditions can be generated by the 
following method. 

Original string: XXXXXXXXXXXn 

XXX...: 10 bytes of characters randomly selected fi-om the following 64 bytes of characters 
are generated. 

n: 0 to MAX_INT (a serial number in the system) 
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"+.ABCDEFGHIJKLMNOPQRSTUVWXYZ0 1 23456789abcdefghijklinnopqrstuvwxyz". 

Here, an original name is acquired by encoding the original string with Base64 
encoding and the above 64 characters. The 64 characters shown here are just an example, 
and any character string can be used as long as it is usable for a file name. 

If an analyzed request is a file erasure request, a file erasure process is performed 
(step 611). Namely, a file with a file name specified and included in the message by a user 
is searched and erased. If an analyzed request is a file list generation request, a file list 
generation process is performed (step 621). 

As a concrete procedure in a preferred embodiment of the present invention, file list 
acquisition division 222 of client terminal 1 10 sends out a servlet to a server. Web server 
140 receives it and then uses message analysis division 264 to determine that the message 
requests execution of a procedure of the present invention and also requires generation of a 
file list. 

And it activates file list generator 262 to extract an original name included in the 
message and retrieve a file including the original name. As a result of retrieval, an HTML 
file is generated by inserting a discovered file in a skeleton file prepared in advance. And a 
URL of the HTML file is included in a message to be posted to the client terminal side. 

In a preferred embodiment of the present invention, a file name of this file list is a 
unique name on this system capable of proving that it was generated by this function. For 
instance, it can be named by input X and a formula: ("dpList" + X). 

The processing results of each processing division 260, 26 1 and 263 are returned to 
client terminal 1 10 which sent the request (step 603). 

Figs. 9 and 10 are diagrams showing processing results of a file list generation 
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process in a preferred embodiment of the present invention. Apart from Web browser 
window 730, an HTML file generated based on a skeleton file is first displayed (browser 
window 740). This is because, in the case that collaboration is performed on Web browser 
window 730, an event which occurred on a Web browser of one client terminal is sent to the 
client terminal of the other party of collaboration consequently interlocking the other party's 
Web browser, while reference to a file list should only be shown to the operator who made 
the request. 

As explained above, the present invention makes it possible, just by a simple 
operation, to display various kinds of information such as an operating state of an 
application, not directly related to communication existing on a client terminal, on a display 
screen of another client terminal. 

Although the present invention has been described with respect to a specific 
preferred embodiment thereof, various changes and modifications may be suggested to one 
skilled in the art and it is intended that the present invention encompass such changes and 
modifications as fall within the scope of the appended claims. 
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